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(54) Web based remote monitoring/control of a measurement instrument 



(57) A measurement instrument is web enabled, en- 
abling it to receive commands or Information to effectu- 
ate an operation on the measurement instrument from 
a user using a browser executing on a remote client 
computer. In response, the operation is effectuated in 
accordance with the commands or information provid- 
ed. Results of the operation, where applicable, are re- 



turned to the browser of the remote client computer for 
the user. The operation may be any one of a number of 
monitoring or control operations, and the commands or 
Information facilitate identification of the nrK>nitoring or 
control operation of interest. The results of the operation 
may include data obtained from the measurement in- 
strument. 
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Description 

Field of the invention 

5 [0001] The present invention relates to the field of measurement instruments. In particular, the present invention 
relates to monitoring or control of a measurement instrument. 

Background of the Invention 

10 [0002] Various measurement instruments including oscilloscopes are known in the art. Measurement instruments 
are used in a wide variety of applications, from measuring engine vibrations to measuring brain waves, just to name 
a couple of examples. Conventional measurement instruments all suffer from at least the following disadvantages: 

(a) monitoring or controlling from a proximity close to the location where measurements are being taken is typically 
IS required, and . . • 

(b) for remote monitoring or control, e.g. in space explorations, proprietary interfaces or mechanism must be spe- 
cifically provided. 

[0003] Since it is often desirable in routine earthly usage of measurement instruments to monitor or control a meas- 
20 urement instrument from a remote location physically separated from the location where measurements are being 
taken, e.g. from an office next door, from an adjacent building, or from a different plant site, it is desirable to have a 
more easily enabled and more user friendly approach to facilitate the desired remote monitoring or control. As will be 
disclosed in more detail below, the present invention achieves these and other desirable results. 

2S SUMMARY OF THE INVENTION 

[0004] A measurement instrument is web enabled, enabling it to receive commands or infornf)ation to effectuate an 
operation on the measurement Instrument from a user using a browser executing on a remote client computer. In 
response, the operation is effectuated in accordance with the commands or information provided. Results of the op- 
30 eration, where applicable, are returned to the browser of the remote client computer for the user. The operation may 
be any one of a number of monitoring or control operations, and the commands or information facilitate identification 
of the monitoring or control operation of interest. The results of the operation returned may include data obtained from 
the measurement instrument. 

[0005] In one embodiment, the measurement instrument is web enabled by coupling the measurement instrument 
35 to a server computer equipped with a web sen/er, a script executor and one or more web pages having one or more 
associated scripts to facilitate the interactions between the user using the browser ot the remote client computer and 
the measurement instrument. 

[0006] In an alternate embodiment, the measurement instrument is equipped with a web based control subsystem 
including a web server, a script executor and one or more web pages having one or more associated scripts to facilitate 
40 the interactions between the user using the browser of the remote client computer and the measurement instrument. 

BRIEF DESCRIPTION OF DRAWINGS 

[0007] The present invention will be described by way of exemplary embodiments, but not limitations, illustrated in 
4S the accompanying drawings in which like references denote similar elements, and in which: 

FIGURE 1 illustrates an oven^iew of the present invention; 

FIGURE 2 is a flow diagram illustrating the method steps of the present invention in accordance with one embod- 
iment; 

so FIGURES 3a-3b illustrate two embodiments of the web enabled measurement instrument of FIGURE 1 ; 

FIGURES 4a-4b illustrate a hardware view and a software view of one embodiment of web based control subsystem 
of Figure 3b; 

FIGURES 5a-5b illustrate two exemplary screens for one embodiment of a web page interface in accordance with 
the present invention; 

55 

DETAILED DESCRIPTION OF THE INVENTION 

[0008] In the following description, various aspects of the present invention will be described. Those skilled in the 
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art will also appreciate that the present invention may be practiced with only some or all aspects of the present invention. 
For purposes of explanation, specific numbers, materials and configurations are set forth in order to provide a thorough 
understanding of the present invention. However, it will also be apparent to one skilled in the art that the present 
invention may be practiced without the specific details. In other instances, well known features are omitted or simplified 

5 in order not to obscure the present invention. 

[0009] Parts of the description will be presented in terms of operations performed by a computer system, using terms 
such as data, flags, bits, values, characters, strings, numbers. Boolean operators, etc., consistent with the manner 
commonly employed by those skilled in the art to convey the substance of their work to others skilled in the art. As well 
understood by those skilled in the art, these quantities take the form of electrical, magnetic, or optical signals capable 

10 of being stored, transferred, combined, and othenwise manipulated through mechanical and electrical components of 
the computer system; and the term computer system includes general purpose as well as special purpose data process- 
ing machines, systems, and the like, that are standalone, adjunct or embedded. 

[0010] Various operations will be described as multiple discrete steps in turn in a manner that is most helpful in 
understanding the present invention, however, the order of description should not be construed as to imply that these 

IS operalbns are necessarily order dependenj, in particular, the order of their presentations. 

[0011] Referring now to Figure 1, a block diagram illustrating an overview of the present invention is shown. As 
Illustrated, in accordance with the present invention, measurement Instrument 112 is web enabled, forming web enabled 
measurement instrument 1 02 that is capable of receiving commands or informatbn to effectuate an operation on meas- 
urement instrument 112 from a user using browser 120 executing on remote client computer 104. Examples of such 

20 operations are monitoring or control operations, and the commands or information are monitoring commands, control 
commands, or information that facilitate identification of the monitoring or control operation of interest. As will be de- 
scribed in more details below, in response, the operation is effectuated in accordance with the commands or information 
provided. Furthermore, results of the operation, if applicable, are returned to browser 120 of remote client computer 
104 for the user. The results of the operation returned may include data obtained from measurement instrument 112, 

25 [0012] Client computer 104 including browser 120 are intended to represent a broad category of these elements 
known in the art. For example, client computer 104 may be model Dimenston® desktop computer, available from Dell 
Computer of Austin Texas, whereas browser 120 may be Navigator® 3.0 available from Netscape Communication of 
Mountain View. OA. As will be readily apparent from the description to follow, the present invention may be practiced 
with a basic browser without additional plug-ins, however, does not preclude their use for additional functions. 

30 [0013] Client computer 104 is coupled to web enabled measurement instrument 102 through communication links 
108 and 110 and communication network(s) 106. Communication links 108 and 110 as well as communication network 
(s) 1 06 are also intended to represent a broad category of these elements known in the art. For example, communication 
network(s) 106 may be a local area network (LAN), such as an Ethernet network, formed with hubs and cables, and 
communlcatbn links 108 and 110 are segments of the LAN. Alternatively, communication netw6rk(s) 106 may be a 

35 private or virtually private wide area network (WAN), such as a frame relay network, formed with router, switches and 
cables, and communication links 108 and 110 are access lines to the WAN. Communication network(s) 106 may also 
be the a public network, such as the Internet, formed with point of presence (POP) providers Interconnected by back- 
bone interconnections, and optionally the public switching telephone network (PSTN), and communication links 108 
and 110 may be networked or dial up links to the POP providers. 

40 [0014] fVleasuremera instrument 102 is web enabled by associating web server 116, script executor 114 and one or 
more web pages 118 with measurement instrument 112. Web pages 118 also include one or more associated scripts 
(not separately shown). Web sen/er 116 in conjunction with at least one of web pages 118 enable the user to conven- 
iently provide monitoring commands, control commands, or information associated with monitoring or control operations 
on measurement Instrument 112 using commonly available browser 120 from a commonly available remote client 

4S computer 1 04. Web server 1 1 6 in conjunction with script executor 114 and web pages 118 (including associated scripts) 
enable measurement instrument 112 to be nrranitored or controlled or data to be extracted responsive to the monitoring 
commands, control commands or information provided. Furthermore, elements 114-118 enable responses of meas- 
urement instrument 112 to the control or the data extracted to be returned to browser 120 and conveniently rendered 
for the user. Web server 116 and script executor 114 are intended to represent a broad category of these elements 

so known in the art. An example of web sen/er 116 is Quid Pro Quo'^^ web server, a shareware software available from 
Social Engineering Inc., of Berkeley, CA, whereas an example of script executor 114 is Frontier Scripting"'^ available 
from UserLand Software of CA. Other web servers and script executors may be employed. The contents of web pages 
118 including their associated scripts are application dependent. In alternate embodiments, In lieu of script executor 
and scripts, equivalent implementations in other high level languages, such as JAVA^** execution environment and 

ss JAVA® applets, may be employed instead. 

[0015] Skipping now to Fig. 5a-5b, two exemplary screens of one embodiment of a web page interface are illustrated. 
For the first exemplary screen, interface web page 500a is a simplified abstraction of the front panel of the measurement 
. instrument, in this case, an oscilloscope. As shown, interface web page 500a includes display area 502 where the 
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measurement data are graphically presented. Additionally, interface web page 500a includes various control buttons 
504 to facilitate user selection of different monitoring or control command groups, e.g. commands associated with 
controlling the vertical setting of the measurement instrument, command associated with controlling the horizontal 
setting of the measurement instrument, and so forth. For the second exemplary screen, interface web page 500b 

5 provides additional commands or input fields to facilitate further user inputs for parameter values associated with se- 
lected command group. As shown, interface web page 500b still includes display area 502 where the measurement 
data are graphically presented. However, in lieu of commands 504, interface web page SOOb includes input fields 506 
to facilitate input of various parameter values associated with the nDonitorIng or control operations. Examples of these 
input fields include the scale, positioning and coupling of a channel, and the source and voltage level of a trigger In 

10 one emtwxliment, interactbns with selected ones of control buttons 504 or input fields 506 result in identifiers of scripts 
to be executed to be provided to the web server, along with the user supplied parameters values, if any 
[0016] Referring now to Fig. 2, the method steps of the present invention in accordance with one embodiment are 
shown in further details. As illustrated, a user desiring to remotely monitor or control a measurement instrument first 
connects to a web sen/er associated with the measurement instrument using a browser executing on a remote client 

IS computer, step 202. In response to the connection, the associated web server presents an interface web page to the 
user, through the connecting browser, step 204. Next, the user interacts with selected ones of the control buttons or 
the input fields to provide the measurement instruments with monitoring commands, control commands, or infomnation 
associated with monitoring or control operations on the measurement instrument, step 206. At step 208, the monitoring 
commands, control commands, or information are sent from the browser to the associated web server. In response to 

^0 the received monitoring commands, control commands, or infomiation, the web server causes one or nrwDre scripts to 
be launched for execution by the script executor, step 210. At step 212, the script executor executes the scripts providing 
commands to the measurement instrument as appropriate. Examples of such commands, in the case of an oscilloscope, 
include but not limited to "autosef, 'setting the vertical scale to a particular scale value", "setting the horizontal scale 
to a particular scale value' and "retrieving the x, y values of the displayed graph". 

25 [0017] At step 214, the measurement Instrument responds to the monitoring commands, control commands, or in- 
formatbn provided, or the data requested of the script executor At step 21 6, the script executor transfers the responses 
of the measurement instrument or the data extracted to the web sender for forwarding to the user At step 218, the web 
server returns the responses of the measurement instrument or the data extracted to the browser for rendering for the 
user. Finally, at step 220, the browser refreshes the interface web page with the responses or data received. 

30 [0018] Steps 208-220 are repeated for as long as the user continues to interact with the interface web page. Even- 
tually, the process terminates when the user disconnects from the web sen/er. 

[0019] Fig. 3a-3b illustrate two embodiments of web enabled measurement instrument 1 02. In Fig. 3a, web enabled 
measurement instrument 102' is formed by externally coupling measurement instrument 112' to server computer 130, 
which is equipped with web sen/er 116*. script executor 114' and one or more web pages 118'. As described earlier, 

3S web pages 118' include one or more associated scripts. For the illustrated embodiment, measurement instrument 112' 
is externally coupled to server computer 130 through communication link 132. In one embodiment, communication link 
132 is a conventional RS232 interface. In alternate embodiments, communication link 132 may be a conventional serial 
interface or a conventional parallel interface instead. In yet other embodiments, communication link 132 may be a bus 
interface instead, such as the universal serial bus or the IEEE 1394 high speed serial bus. 

40 [0020] In Fig. 3b, web enabled measurement instrument 102" is formed by closely coupling acquisition subsystem 
146 and display subsystem 150 of measurement instrument 112" to newly provided web based control subsystem 
160. In other words, newly provided web based control subsystem 160 and the conventional subsystems, i.e. subsys- 
tems 142-150, together form an integrated web enabled measurement instrument 102". Vertical subsystem 142, trigger 
subsystem 144, acquisitfon subsystem 146, horizontal subsystem 148 and display subsystem 150 are intended to 

4S represent a broad category of these elements known in the art. Each of elements 142-150 performs its conventional 
functions, and the elements' constitutions are known. Accordingly, elements 142-150 will not be further described. 
[0021] Fig. 4a-4b illustrate an hardware and a software view of an exemplary embodiment of web based control 
subsystem 160. As shown in Fig. 4a, for the illustrated embodiment, web based control subsystem 160' includes 
processor 402, non-volatile storage 404, memory 406, bus bridge 408, and I/O interface 410, coupled to each other 

so through internal bus 41 2. Bus bridge 408 is also coupled to the acquisition subsystem to facilitate provision of monitoring 
or control commands and receipt of responses of the acquisition subsystem to and from the acquisition subsystem, 
whereas I/O interface 410 facilitates receipt of the graphical display data from the acquisition subsystem. In one em- 
bodiment. Internal bus 412 Is a peripheral component interconnect (PCI) bus. whereas bus bridge 408 is a PCl-PCI 
bridge. As shown in Fig. 4b, non-volatile storage 404 and memory 406 are used to store the permanent and working 

55 copies of the web sen/er, the script executor, and the web pages including the associated scripts described earlier 
The permanent copy of the web sen/er etc. may be preloaded in the factory or field installed (if web enabled measure- 
ment instrument 102" also includes the necessary input or communication devices). Elements 402-412 are all intended 
to represent a broad category of these elements known in the art. Each of elements 402-412 perform its conventional 
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functions known in the art. and their constitutions are known. Accordingly, elements 402>41 2 will not be further described 
either. 

[0022] Tables 1-9 illustrate various exemplary scripts suitable lor used to practice the present invention. Tables 1-7 
form a single script, and are designated a separate tables merely for convenience in referring to the different sections 

5 of the script. In particular, Tables 1 -7 illustrate an exemplary script suitable for use to generate a front panel" web page 
for the user. For the exemplary script, table 1 describes various relevant parameters, e.g. the client's IP address, the 
sen/er name, the TCP/IP port of the server, and so forth. Table 2 describes the logic associated with the various actions 
to be taken in response to certain user actions. Table 3 describes the various command "buttons" to be included and 
displayed for the web page. Tables 4 and 5 illustrates two exemplary scripts for generating enumerated and text choices 

JO for input fields of the web page. Table 6 describes the associated logic. Finally, tables 7 and 8 illustrate two exemplary 
scripts for providing monitoring or control commands to the measurement instrument. Table 7 illustrates the exemplary 
source code for querying an oscilloscope's current settings, whereas Table 6 illustrates the exemplary source code for 
capturing the current measurement data. The precise meaning of these statements are unimportant, even though they 
are readily apparent to those skilled in the art. The exemplary scripts are merely shown for illustrative purpose. The 

IS ^ precise statements to be employed are application dependent, i.e. depen^Jent on the type of measurement instrument, 
the type of end user interlace offered, the number and types of user commands and input fields offered, the nature of 
responses to the various user actions, and so forth. Implementations of these and other application dependent scripts 
are well within the ability of those skilled in the art. Accordingly, they will not be further described. 

20 

Table 1 

>on frontpanel (adrParams) 

« Available parameters [WebSTAR 1 .2) 

« pathArgs - stuff in the URL after a $ 
2S « httpSearchArgs - stuff in the URL after a ? 

« usemame - authenicated user name 

« password - authenicated password 

« fromUser - not required by http std. e-mail address of remote user 

« clientAddress - IP address or domain name of remote client's host 
30 « serverName - name or IP address of this server 

« serverPort - TCP/IP port number being used by this sen/er 

« scriptName - URL name of this script 

« contentType - MIME content of post_args 

« referer - the URL of the page referencing this document 
55 « userAgent - the name and version of the WWW client software being used 

« action - the action name, if the script was an action (or CGI, ACGI. ...) 

« aclionPath - the Mac path to the action CGI (this script) 

« postArgs - stuff sent from forms, etc. when POST method is used 

« method - GET, POST, etc. Used to tell if post_args are valid 
^ « clientIP - IP address of the client 

« fullRequest - the entire HTTP request received from the client 

« connectionID - unique ID of http connection 

« argTable.xxx - form data when POST method is used, where xxx is the field name 



so 



ss 
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Table 2 

local (hlmllexl = webServer.httpHeader 0) 
on add (s) 

> htmltext = htmltext +s + cr 
with adfParams'^ 

>addC<html>-) 

> add C<head>-) 

>add (<title>TekScope Front Panel</title>') 

> add ("<yhead>") 

> add C<body>") 

> if defined (argTable. Key) 

> with workspace 

> local . 

>comandSlring=argTable.key 
> errorMessage='^ 

> add C<P>Key: "commandString+"<P>") 

> commandString = ":FPANEL:PRESS "+commandSlring 

> en'orMessage = SendCommandNoOpen(commandString) 
• > if (errorMessage =="") 

> add ("{command executed without Frontier en'crs)<P>") 

> else 

> add {*'<P>(command returned error:"+ errorMessage +-)<P>") 

> if defined (argTable.Tum) 

> with workspace 

> local 

> commandString =argTableTum 
> !, numTums 

> errorMessage = 

> add ("<P>Tums: "+commandString*"<P>") 

> commandString = "iFPANELiTURN "+commandString 

> bundle = Get number of turns 

> local 

> numLength, numStart 

> numStart = string.pattemMatchf.". commandString)+1 

> numLength = string.length(commandStririg) - numStart* 1 

> numTums = short(slring.mid(commandString, numStart. nunriLength))) 

> numTums = abs(numTums) 

> for I = 1 to numTums 

> en'ori\/lessage = SendCommandNoOpen(commandString) 

> rf (errorMessage ! 

> break 

> if (errorMesage 

> add ("command executed without Frontier errors)<P>**) 

> else 

> addf <P>(command retumed error: " en'orMessage+'*)<P>'') 

> add{"<P>(loop Index: "+ I +":NumTums: ": " + numTums +")<P>*) 
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Tabte3 

> with workspace 

> local 

> imageName 

> if (string.mid(imageName.1.3)!="ERR') 

> add ('•<image src=\'scopeimagesr+imageName+T>") 
>else 

> add("<P> Error reading image<P>") 

> bundle Add form for keypad 

> on addKey (keyString) 

> addr<INPUT TYPE=rSUBMm' NAME=\'Key\- 
VALUE=r+keyString+T>-) 

> on addTum (tumString) 

> addr<INPUT TYPE=\''SUBMIT\' NAME=\Tum\" 
VALUE=r+tumSlring+V>'') 

> add(**<FORM ACTION=rhttp://126.181.40.171/tekscope.frontpaneLfcgi\" 
METHOD=POST>-) 

> addr<INPUT TYPE=\"SUBMm" NAME=\-Refresh\">") 

> add("<BR>") 

> bundle ..bezel buttons, dear menu, and toggle 

>addKeyrBMenu1") 

> addKeyrBMenu2") 

> addKeyCBMenuS") 

> addKeyrBMenu4") 

> addKey("ClearMenu") 

> addKey(*Toggle") 

> addr<BR>") 

> bundle ..Meter, Hold.Acquire.Meas.Curscrs 

> addKeyC'Meter") 

> addKey("RunStop'0 

> addKeyCAcquireT 

> addKeyfMeasMenu") 

> addKeyfCursors") 

> add(-<BR>-) 

> bundle ..Scope, AutoRange. Save/Recall, Display. Utility 

> addKeyCScope") 

> addKey^AutoRange") 

> addKeyfSRSelup") 

> addKeyC'Display") 

> addKeyfUtiiity") 
>add("<BR>") 

> bundle ..Ch1. Ch2, Math, RefA, RefB, WfmOff 

>addKey("Ch1") 

> addKey("Ch2") 

> addKeyCMath") 

> addKeyCRefA") 

> addKeyCRefB") 

> addKeyCWfmOfT) 

> addr<BR>") 
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> bundle ,.Vert Menu. Horiz Menu, Trigger Menu, Mag. 50% 

> addKeyCVertMenuT 

> addKeyCHotzMenu") 
>addKeyCMa9-) 

> addKey("TrigMenu') 

> addKey("SetLever) 

> add('*<BR>'') 

> bundle ..Knobs 

> bundle ..Positive turns 

> addTumCVertScale.+1') 

> addTum("Vertpos.+25'') 
>addTum(''HorzScale.+r) , . 

> addTumCHofzPos.+25") 

> addTumCTrigLevel +25") 

> addTumrGPKnob.+1") 

> addr<BR>-) 

> bundle ..Negitive turns 

> addTumfVertScale.-r) 

> addTum("Vertpos.-25'') 

> addTum("HorzScale.-1 ") 

> addTumCHor7Pos.-25") 

> addTumf TrigLevel.-25") 

> addTum(-GPKnob.-r) 

> addr<BR>-) 

> addC</FORM>") 
addC</body>'') 
addC</html>'-) 
retum(htmltext) 
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Table 5 

> On GenerateSelectTag (theCommand. theName, theOptions) 

> local 

> theTag 

> theCurrentSetting 

> i 

> on add (s) 

> theTag = theTag +s + char(13) 

> theCun-entSetting = workspace.QueryScopeSetting(theCommand) 

> add (-<SELECT NAME=V =theName + T SIZE=1>'') 
>local 

> theOptionName 

> theOptionLabel 

> theOptionTag 

> for I =1 to sizeOf (theOptions) 

> theOptionName = theOptions(i)[1] 

> theOptionLabel = theOptions(i)[2] 

> theOptionTag =''<OPT10N VALUE=\"'' + theOptionName +T'' 

> if (theOptionName= = theCurrentSetting) 

> theOptionTag = theOptionTag + "SELECTED" 

> theOptionTag = theOptionTag + + theOptionLabel 



>add (theOptionTag) 
> add (•</SELECT>-) 
>retum theTag 

>GenerateSelectTag CCH!:SCA. -ChlScale", {{"5.06-3". "5 m\r}A 

> ri.0E-2", -lOmV"}. r2.0E-2-. "20 mV'},^5.0E-2^ "50 m\n.\ 

> ri.0E-r. -100mV-}, r2.0E-r. "200 m\n.r5.0E-r. "500 m\r}.\ 

> ri.oE-o-. -1 \n. r*2.oE-o-. -2 \o.r5.0E-0". -5 V-}.\ 

> ri.OEr, "10 \0. r2.0Er. -20 Nn.rS OEl". "SO VIA 

>}) 

«aaaRecordTestScript (ACQ:MODE".{{"SAM". "SAMPLE"}A 

«f PEAK", "Peak Detect^. fAVE", "Average"). fENV, "Envelope"}}) 



Table 6 

> On GenerateTextTag (theCommand, theName. theSize) 

> local 

> theTag 

> theCurrentSetting 

> i 

> theCurrentSetting = workspace. OueryScopeSetting(theCommand) 

> theTag=-<iNPUT TYPE=TEXT SI2E=" ♦theSize +"Name=\" +theName + -\-VALUE="+\ 

> theCurrentSetting + 

> return theTag 

> msg(GenerateTextTag ("iTRlGGERiMAINiLEVEL-.TrigLever.S)) 
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Table 7 

> On QueryScopeSetting (setti'ngToQuery) 

> local 

> queryResponse 

> errorA^sg 

> if string.nthChar(settingToQuery, string.length(settingToQuery)) 1="?" 

> setlingToQuery = settingToQuery + 

> with system.extensions.SerialPortCommands, workspace 

> try 

> sendStringSIowly (settingToQuery + ScopeEOL) 

> queryResponse = workspace.ReadSerialLine(ScopeSerialPort. 
180)(setlingToQuery ♦ ScopeEOL) 

> return queryResponse 

> else 

> errorMsg = "error: +try Error +"Querying: " + settingToQuery Port " 
ScopeSerialPort 

« msgCenrorMsg) 

> scriptError{tryError)] 
>retum(erTorMsg) 

> dialog.AlenfAcquire mode: " + QueryScopeSettingf :ACUIRE:MODE")) 



Table 8 

> on GrabNewScreenForFCGI () 
> with workspace. clip2gif 
> local 
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> gifName, gifPath 

> bundle = Make sure ODB variables are defined 

> if not (defined(workspace.ScopeGIFFolder)) 

> workspace.ScopeGIFFolder = "Macintosh HD:MikeGauland:Quid Pro 
Quo:scopeimages:' 

> if not (file exists(workspace.ScopeGIFFolder)) 

> file.newFolder(workspace.ScopeGIFFolder) 

> if not (definedCworkspace.ScopeGIFNumber)) 

> workspace. ScopeG I FNumber=0 

> gifName = "screen" +ScopeGIFNumber +"-gir 

> gifPath = ScopeGIFFolder +gifName 

> ScopeGIFNumber= ScopeGIFNumber+1 

> errorMessage= GrabSCreenNoOpenCRAM Diskiscope.tif^ 

> if (errorMessage=="') 

> app.start f clip2gin 

> app.bringToFrontO 

«save ("RAM Dlsk:scope.tir, savein:" gifPath", as:gjO 

> save (RAM Disk:scope.tir. saveln:"RAM Disk:scope.gir. as:gif. depth:1) 

> Frontier. bringToFrontO 

> local 

> gif Data 

>file.open ("RAM Disk:scope.tif^ 

> gifData = file.readCRAM Diskiscope.gif . infinity) 

> gifData [19]= Oxff 

> file.cIose("RAM Diskrscope.giT) 

> gifData [19]= Oxff 

> file.new(gifPath) 

> file.setCreator(gifPath/c2gf ) 

> file.setType(gifPath;GIFfr) 

> file.write(gifPath, gifData) 

> file.setCreator(gifPath.'c2gf ) 

> fiIe.setCreator(gifPath;c2gf ) 

> file.close(gifPath) 

> return gifName 

> else 

> return "ERR" +errorMessage 
> GrabNewScreenForFCGI 0 



[0023] In general, those skilled in the art will appreciate that through the novel approach of web enabling a meas- 
urement instrument as described earlier, a user is advantageously enabled to monitor or control the measurement 
instrument remotely through commonly available tools such as a browser executing on a commonly available client 
computer, a very user friendly approach. Furthermore, the web enabling approach described earlier may be effectuated 
through substantially "off-the-shelf' components, without resorting to costly and burdensome proprietary interfaces 
and mechanisms. 

[0024] Those skilled in the art will also recognize that the present invention is not limited by the details nor the 
embodiments described. Instead, the present invention can be practiced with modifications and alterations within the 
spirit and scope of the appended claims. The descriptk>n is thus to be regarded as illustrative instead of restrictive on 
the present invention. 

[0025] Thus, a method and apparatus for remote monitoring or control of a measurement instrument has been de- 
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Claims 

5 

1. In a server computer, a machine implemented method comprising the steps of: 

a) providing by a web server to an executor, both executing on the server computer, commands or information, 
received by the web server from a browser executing on a remote client computer, corresponding to an oper- 

10 ation to be effectuated on a measurement instrument; and 

b) effectuating the operation on the measurement instrument by the executor in accordance with the commands 
or information provided by the web server. 

2. The method of claim 1 wherein 

the step of providing comprises receiving by the web server information identifying a collection of executable 
Instructtons to be executed to effectuate the operation on the measurement instrument, from the browser of 
the remote client computer, and providing by the web sen/er to the executor the identified collection of exe- 
cutable instructions; and 

20 the step of effectuating comprises executing by the executor the identified collection of executable instructions. 

3. The method of claim 1 wherein the step of effectuating comprises forwarding a control or data obtaining command 
to the measurement instrument by the executor of the server computer. 

25 4. The method of claim 1 wherein method further comprises the step of: 

c) forwarding results of the effectuated operation to the browser of the remote client computer by the web 
server of the server computer. 

30 5. The method of claim 4 wherein the step of fonwarding further comprises receiving by the executor responses of 
the measurement instrument or data being obtained, and providing by the executor to the web server the received 
responses or data obtained. 

6. In a measurement instrument, a method comprising the steps of: 

3S 

a) providing control or data obtaining commands by a web based control subsystem to an acquisition subsys- 
tem, both subsystems of the measurement instrument, in response to commands or information to effectuate 
an operation on the measurement instrument receiving by the web based control subsystem from a browser 
executing on a remote client computer; and 
40 b) operating the measurement instrument by the acquisition subsystem in accordance with the control or data 

obtaining commands provided. 

7. The method of claim 6 wherein the step of providing comprises receiving by a web sen/er of the web based control 
subsystem, from the browser of the remote client computer, infornnation identifying a collection of instructions to 

45 be executed to effectuate the operation, providing by the web server to an executor of the web based control 

subsystem the received identification information, and executing the identified collection of instructbns by the 
executor, which results in the provision of the control or data obtaining commands to the acquisitton subsystem. 

a The method of claim 6 wherein the method further comprises the step of: 
so . 

c) providing results of the operation by the web based control subsystem to the browser of the remote client 
computer. 

9. The method of claim 8 wherein the step ot providing comprises receiving by an executor of the web based control 
55 subsystem of the measurement instrument responses or data being obtained from the acquisition subsystem of 

the measurement instrument, providing by the executor to a web server of the web based control subsystem the 
received responses or data obtained, and f onwarding by the web server to the browser of the remote client computer 
the provided responses or data obtained. 
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10. A server computer conriprlsing: 

a storage medium having stored therein a first and a second plurality of programming instructions that imple- 
ment a web server and an executor respectively, when executed, enabling the server computer to operate to 
5 receive commands or information to effectuate an operation on a measurement instrument from a browser of 

a remote client computer, enabling the server computer to operate the measurement instrument responsive 
to the received commands or information, and forwarding results of the operation, when applicable, to the 
browser of the remote client computer; and 

(b) a processor coupled to the storage medium to execute the first and second plurality of programming In- 
10 St ructions. 

11. The server computer of claim 10 wherein, when executed, the first plurality of programming instructions imple- 
menting the web sen/er enable the server computer to receive information corresponding to a third plurality of 
programming instructions to be executed to effectuate the operation on the measurement instrument from the 

JS browser of the remote client computer, and provide the received information to the executor. 

12. The server computer of claim 10 wherein, when executed, the second plurality of programming Instructions Imple- 
menting the executor enable the server computer to execute a third plurality of programming instructions to effec- 
tuate the operation on the measurement instrument, Including forwarding of a control command to the measure- 

20 ment instrument. 

13. The server computer of claim 10 wherein, when executed, the second plurality of programming instructions imple- 
menting the executor enable the sen/er computer to execute a third plurality of programming instructions to effec- 
tuate the operation on the measurement instrument, including fonwarding of a data obtaining command to the 

2S measurement instrument, receiving the data being obtained from the measurement instrument, and providing the 

received data to the web sen/er for forwarding to the browser of the remote client computer. 

1 4. The server compute r of claim 1 0 wherein the server computer further comprises a first and a second communication 
interface coupling the remote client computer and the measurement instrument to the server computer respectively 

30 

15. A measurement instrument comprising: 

an acquisition subsystem to be used to acquire measurement data; and 

a web based control subsystem coupled to the acquisition subsystem to be used to receive commands or 
55 information corresponding to an operation from a browser executing on a remote client computer, and to cause 

the acquisition subsystem to effectuate the operation responsive to the received commands or infornnation. 

16. The measurement instruction of claim 15 wherein the web based control subsystem comprises: 

40 a storage medium having stored therein a first plurality of programming instructions implementing a web server. 

when executed, enabling the web based control subsystem to receive from the browser of the remote client 
computer, information corresponding to a second plurality of programming instructions to be executed to cause 
the operation to be effectuated by the acquisition subsystem, and when applicable, to fonward responses of 
the acquisition subsystem to the browser of the remote client computer; and 

4S a processor coupled to the storage medium to be used to execute the first plurality of programming instructions. 

17. The measurement instrument of claim 16 wherein the responses of the acquisition subsystem fonwarded include 
data obtained from the acquisition subsystem. 

so 18. The measurement instruction of claim 15 wherein the web based control subsystem comprises: 

a storage medium having stored therein a first plurality of programming instructions implementing an executor, 
when executed, enabling the web based control subsystem to execute a second plurality of programming 
instructions to cause the acquisition subsystem to effectuate the operation on the measurement instrument, 
55 and when applicable, receiving responses of the acquisition subsystem to be forwarded to the browser of the 

remote client computer; and 

a processor coupled to the storage medium to be used to execute the first plurality of programming instructions. 
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19. The measurement instrument of claim 18 wherein the storage medium further having stored therein the second 
plurality of programming instructions, and the processor is also used to execute the second plurality of programming 
instructions. 

20. The measurement instrument of claim 1 8 wherein when executed, the second plurality of programming instructtons 
cause a control of data obtaining command to be provided from the web based control subsystem to the acquisition 
subsystern. 

21. A computer program for implementing a method as claimed in any one of claims 1 to 9. 

22. A computer-readable storage medium storing a program as claimed in claim 21 . 
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